<%--
  Created by IntelliJ IDEA.
  User: Administrator
  Date: 2022/9/24
  Time: 9:06
  To change this template use File | Settings | File Templates.
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<%@taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>

<html>
<head>
    <title>学生展示</title>
    <!-- 注意：项目正式环境请勿引用该地址 -->
    <link rel="stylesheet" href="${pageContext.request.contextPath}/static/layui-v2.7.6/layui/css/layui.css" >
</head>
<body>
<script type="text/html" id="barDemo">
    <a class="layui-btn layui-btn-xs" lay-event="edit" >编辑</a>
<%--    <a class="layui-btn layui-btn-danger layui-btn-xs" lay-event="del">删除</a>--%>
</script>

<script type="text/html" id="toolbarDemo">
    <div class="layui-btn-container">
        <button class="layui-btn layui-btn-sm" lay-event="addStu">添加</button>
        <button class="layui-btn layui-btn-sm" lay-event="getCheckData">获取选中行数据</button>
        <button class="layui-btn layui-btn-sm" lay-event="getData">获取当前页数据</button>
        <button class="layui-btn layui-btn-sm" lay-event="isAll">是否全选</button>
    </div>
</script>
<form class="layui-form" action=""  id="saveUserForm" style=" display: none"  lay-filter="updateUserFormFilter">
    <input type="hidden" name="id" >

    <form class="layui-form" enctype="multipart/form-data" action="" >

        <div class="registerbox-title">用户注册中心</div>
        <div class="layui-form-item">
            <div class="layui-form-item pass" >
                <label class="layui-form-label">用户id</label>
                <div class="layui-input-inline">
                    <input type="text" name="id" autocomplete="off" disabled="none"
                           class="layui-input" id="id">
                </div>
            </div>
            <label class="layui-form-label">用户账号</label>
            <div class="layui-input-inline">
                <input type="text" name="username" id="username" onblur="checkUsername(this)"  lay-verify="required" placeholder="请输入账号" autocomplete="off"
                       class="layui-input">
            </div>
        </div>

            <div class="layui-form-item pass" >
                <label class="layui-form-label">用户密码</label>
                <div class="layui-input-inline">
                    <input type="password" name="password"  lay-verify="required" placeholder="请输入密码" autocomplete="off"
                           class="layui-input" id="pass1">
                </div>
            </div>
            <div class="layui-form-item pass" >
                <label class="layui-form-label">确认密码</label>
                <div class="layui-input-inline">
                    <input type="password" name="password"  lay-verify="required|pass" placeholder="请再次输入密码"
                           autocomplete="off" class="layui-input" id="pass2">
                </div>
            </div>

        <div class="layui-form-item">
            <label class="layui-form-label">性别</label>
            <div class="layui-input-block">
                <input type="radio" name="sex" value="男" title="男" checked="">
                <input type="radio" name="sex" value="女" title="女">
            </div>
        </div>

        <div class="layui-form-item">
            <label class="layui-form-label">角色</label>
            <div class="layui-input-block">
                <select name="rid" id="rid"  class="layui-select roleSelect">
<%--                    <option value="">请选择...</option>--%>
<%--                    <option value="2">员工</option>--%>
<%--                    <option value="1">管理员</option>--%>
                </select>
            </div>
        </div>


        <%--状态--%>
        <div class="layui-form-item">
            <label class="layui-form-label">状态</label>
            <div class="layui-input-block">
                <input type="hidden"  id="status" name="status" value="1"/>
                <input type="checkbox" name="statusswitch" checked  lay-skin="switch" lay-filter="switchStatus" lay-text="启用|禁用">
            </div>
        </div>

        <%--开关   选中的时候 on   未选中的时候 off  一般不用开关传值   on 1  off 2--%>


        <div class="layui-form-item">
            <div class="layui-upload" style="margin-left: 90px">
                <button type="button" class="layui-btn" id="test1">上传图片</button>
                <div class="layui-upload-list" style="margin:10px -3px;">

                    <img class="layui-upload-img"
                         width="100px" height="100px" style="border-radius: 50%" id="demo1" src="${pageContext.request.contextPath}/static/img/a.jpg">
                    <p id="demoText"></p>
                </div>
                <!--上传返回的图片地址-->
                <input type="hidden" name="imgpath" id="uploadImg" value="">
            </div>
        </div>


        <div class="layui-form-item">
            <div class="layui-input-block">
                    <button class="layui-btn" lay-submit lay-filter="formSaveUser">注册</button>
                    <button type="reset" class="layui-btn layui-btn-primary">重置</button>
            </div>
        </div>


    </form>


<%----%>


    <%--查询条件--%>
    <form class="layui-form" action="">
        <div class="layui-inline">
            <label class="layui-form-label">用户名</label>
            <div class="layui-input-inline">
                <input type="text" name="username" placeholder="请输入用户名" autocomplete="off" class="layui-input">
            </div>
        </div>

        <div class="layui-inline">
            <label class="layui-form-label">状态</label>
            <div class="layui-input-block">
                <select name="status"  class="layui-select">
                    <option value="">请选择...</option>
                    <option value="1">启用</option>
                    <option value="2">禁用</option>
                </select>
                <%--                <input type="text" name="username" placeholder="请输入用户名" autocomplete="off" class="layui-input">--%>
            </div>
        </div>
        <div class="layui-inline">
            <label class="layui-form-label">角色</label>
            <div class="layui-input-block">
                <select name="rid"   class="layui-select roleSelect">
                    <option value="">请选择...</option>
                </select>
                <%--                <input type="text" name="username" placeholder="请输入用户名" autocomplete="off" class="layui-input">--%>
            </div>
        </div>

        <div class="layui-inline">
            <div class="layui-input-inline">
                <button class="layui-btn" lay-submit lay-filter="formDemo">查询</button>
                <button type="reset" class="layui-btn layui-btn-primary">重置</button>
            </div>
        </div>
    </form>
<table class="layui-hide" id="test" lay-filter = "test"></table>
<!-- 注意：项目正式环境请勿引用该地址 -->
<script src="${pageContext.request.contextPath}/static/layui-v2.7.6/layui/layui.js"></script>
    <script src="${pageContext.request.contextPath}/static/jquery-3.6.1.min.js"></script>
    <script>
        $(function () {


    layui.use(['table','layer','form','jquery'], function(){
        var table = layui.table;
        var layer = layui.layer;
        var form = layui.form;
        var $ = layui.jquery;
        var upload = layui.upload
            , element = layui.element;
        var namestatus=true;

        table.render({
            // element  元素
            elem: '#test'
            ,page:true
            ,limit:2
            ,limits:[2,4,6,8]
            ,toolbar: '#toolbarDemo'
            ,url:'${pageContext.request.contextPath}/query' //  表格了里面所需要的数据就是一个list里面有很多的map、对象
            ,cellMinWidth: 80 //全局定义常规单元格的最小宽度，layui 2.2.1 新增
            ,totalRow: true // 开启合计行
            //传过来的数据进行处理  laydata
            ,parseData: function (res) {
            return {
                   "code":res.code,
                   "msg":res.msg,
                    "count": res.data.total,//从返回的json数据中取出总行数
                    "data": res.data.list//返回的json数据有两层，layui不支持多层数据，所以是res.list
                }
             }
            ,cols: [[
                {type: 'checkbox', fixed: 'left'}
                // field 后面跟的内容  必须跟后台传过来的数据里面的map 的key保持一致
                ,{field:'id', title: 'ID', sort: true}
                ,{field:'username', title: '用户名'} //width 支持：数字、百分比和不填写。你还可以通过 minWidth 参数局部定义当前单元格的最小宽度，layui 2.2.1 新增
                ,{field:'sex', title: '性别', sort: true}
                ,{field: 'role',title: '角色',sort: true,templet:function (d) {
                        return '<span>'+d.role.rolename+'</span>';;
                    } }
                ,{field:'imgpath', title: '头像', sort: true,templet:function(d){

                    return '<div><img width="100px" height="100px" src='+d.imgpath+'></div>';
                    }}
                ,{field:'status', title: '状态', sort: true,templet:function(d){
                if (d.role.rolename !="管理员") {
                    if (d.status == 1) {
                         return '<input type="checkbox" checked value="' + d.id + '"  lay-skin="switch" lay-filter="switchStatus1" lay-text="启用|禁用">';
                    } else {
                         return '<input type="checkbox" value="' + d.id + '"   lay-skin="switch" lay-filter="switchStatus1" lay-text="启用|禁用">';
                         }
                        }else {
                    return '<input type="checkbox" checked value="' + d.id + '"  disabled lay-skin="switch" lay-filter="switchStatus1" lay-text="启用|禁用">'
                }
                    }}
                ,{fixed: 'right', title:'操作', width: 125, minWidth: 125, toolbar: '#barDemo'}
            ]]

        });


        // // 自定义校验  验证两次密码是不是一样
        form.verify({
            pass: function(value){ //自定义lay-verify的昵称，value：表单的值
                var pass1 = $("#pass1").val();
                if(value!=pass1){
                    return "两次密码不一致！！！";
                }

            }
        });

        // 监听单元格里面的开关
        form.on('switch(switchStatus1)', function(obj){
            //alert(JSON.stringify(obj));
            var status=1;
            if(this.checked){
                status=1
            }else{
                status=2;
            }
            // 修改这条数据的状态即可
            $.ajax({
                type:"post",
                data:{id:obj.value,status:status},
                url:"${pageContext.request.contextPath}/updatas",
                success:function(d){
                    if(d.code==0){
                        layer.msg("修改成功",{icon:"1"});
                        table.reload('test');
                    }
                }
            })

        });

        // 工具栏事件
        table.on('toolbar(test)', function(obj){
            var uid = obj.config.uid;
            var checkStatus = table.checkStatus(uid);
            var othis = lay(this);
            switch(obj.event){
                case 'getCheckData':
                    var data = checkStatus.data;
                    layer.alert(layui.util.escape(JSON.stringify(data)));
                    break;
                case 'getData':
                    var getData = table.getData(id);
                    console.log(getData);
                    layer.alert(layui.util.escape(JSON.stringify(getData)));
                    break;
                case 'isAll':
                    layer.msg(checkStatus.isAll ? '全选': '未全选')
                    break;
                case 'addStu':
                    $("#saveUserForm")[0].reset();
                    $(".pass").css("display","block");
                    layer.open({
                        type: 1,
                        area: ['500px', '400px'],
                        offset: '100px',
                        content:$("#saveUserForm"),
                        cancel: function(index, layero){

                            layer.close(index);
                            $("#saveUserForm").hide();
                            return false;
                        }



                    });
                    break;
            };
        });

        //触发单元格工具事件
        //监听行工具事件
        table.on('tool(test)', function(obj){
            var data = obj.data;
            //console.log(obj)

            if(obj.event === 'edit'){
                $(".pass").css("display","none");
                document.getElementById("username").onblur = function () {
                };
                layer.open({
                    type: 1,
                    area: ['500px', '400px'],
                    offset: '100px',
                    content:$("#saveUserForm"),
                    cancel: function (index, layero) {

                        layer.close(index);
                        $("#saveUserForm").hide();
                        return false;
                    }
                });
                form.val('')

                // 给开关赋值
                if(data.status==1){
                    data.statusswitch=true;
                }else{
                    data.statusswitch=false;
                }

                form.val('updateUserFormFilter',data);
                $("#demo1").prop("src",data.imgpath);


            }
        });

        // 监听开关
        form.on("switch(switchStatus)",function (d){
            // 选中的时候  状态的值1   未选中的时候  2
            var flage=$(this).prop("checked");
            if(flage==true){
                $("#status").val(1);
            }else{
                $("#status").val(2);
            }
        })

        //提交表单
        // Layui提交表单 监听提交  data代表的是form表单里面的所有的内容
        form.on('submit(formSaveUser)', function(data){
            var id=$("#id").val();
            var username=$("#username").val();
            var password=$("#pass1").val();
            var sex=$('input[name="sex"]:checked').val()
            var status=$("#status").val();
            var rid=$("#rid").val();
            var imgpath=$("#uploadImg").val();
            var params = {};
            params.id=id;
            params.username=username;
            params.password=password;
            params.sex=sex;
            params.status=status;
            params.rid=rid;
            params.imgpath=imgpath;
            if(namestatus){
                $.ajax({
                    url:"${pageContext.request.contextPath}/add",
                    type:"post",
                    dataType:"JSON",
                    data:params,//表单里所有数据
                    success:function (ret){
                        if (ret.data == true){
                            //关闭所有弹框
                            layer.closeAll();
                            //隐藏表单
                            $("#formSaveUser").hide();
                            //刷新页面
                            table.reload('test');
                            $("#saveUserForm").hide();
                        }
                    }
                })
            }
            return false;
        });

        // 文件上传
        //常规使用 - 普通图片上传
        var uploadInst = upload.render({
            elem: '#test1'
            , url: '${pageContext.request.contextPath}/upload' //此处用的是第三方的 http 请求演示，实际使用时改成您自己的上传接口即可。
            , before: function (obj) {
                //预读本地文件示例，不支持ie8
                obj.preview(function (index, file, result) {
                    $('#demo1').attr('src', result); //图片链接（base64）
                });

                // element.progress('demo', '0%'); //进度条复位
                // layer.msg('上传中', {icon: 16, time: 0});
            }
            , done: function (res) {

                alert(JSON.stringify(res));
                //如果上传失败
                if (res.code > 0) {
                    return layer.msg('上传失败');
                }
                //上传成功的一些操作
                //……
                $("#uploadImg").val(res.data);
                alert($("#uploadImg").val());
            }
            , error: function () {
                //演示失败状态，并实现重传
                var demoText = $('#demoText');
                demoText.html('<span style="color: #FF5722;">上传失败</span> <a class="layui-btn layui-btn-xs demo-reload">重试</a>');
                demoText.find('.demo-reload').on('click', function () {
                    uploadInst.upload();
                });
            }
            , progress: function (n, elem, e) {
                element.progress('demo', n + '%'); //可配合 layui 进度条元素使用
                if (n == 100) {
                    layer.msg('上传完毕', {icon: 1});
                }
            }
        });


        checkUsername=function (obj){
            namestatus=true;
            var data=$("#username").val();
            $.ajax({
                url:`${pageContext.request.contextPath}/`+data,
                type:"post",
                success:function(d){
                    //alert(d.data);
                    if(d.data==false){
                        namestatus=false;
                        layer.alert("该名字已经存在！！！");
                    }
                }
            })
        }
        //模糊查询
        form.on('submit(formDemo)', function(data){
            console.log(data.elem) //被执行事件的元素DOM对象，一般为button对象
            console.log(data.form) //被执行提交的form对象，一般在存在form标签时才会返回
            console.log(data.field) //当前容器的全部表单字段，名值对形式：{name: value}
            //alert(JSON.stringify(data.field))
            table.reload('test', {
                // where: { //请求参数（注意：这里面的参数可任意定义，并非下面固定的格式）
                //     searchUserid: data.field.userid //排序字段
                //     ,searchUsername:data.field.username//排序方式
                //     }
                where:data.field,
                page: {    curr: 1 //重新从第 1 页开始
                },
            });

            return false; //阻止表单跳转。如果需要表单跳转，去掉这段即可。
        });
    });
            //发出ajax请求 角色所有的信息
            $.ajax({
                url:"${pageContext.request.contextPath}/tRole",
                type:"get",
                success:function (d) {
                    var data=d.data;
                    //alert(JSON.stringify(data.list))
                    if(d.code==0){
                        //<option value="0">写作</option>
                        var htmlStr="<option value=''>--请选择--</option>";
                        for (let i = 0; i < data.list.length; i++) {
                            htmlStr+="<option value="+data.list[i].rid+">"+data.list[i].rolename+"</option>"
                        }
                        // alert(htmlStr);
                        $(".roleSelect").html(htmlStr);
                        //重新渲染表单

                        layui.use('form',function () {
                            var form=  layui.form;
                            form.render('select');
                        })

                    }

                },

    });
        })


</script>

</body>
</html>
